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(54) Variable length register device 

(57) It is an object of the invention to provide a vari- 
able length register device which can be used not only 
for assigning an address of a memory but also as a gen- 
eral register. A memory outputs an instruction to gain 
access to a variable length register. A decoder decodes 
the instruction supplied from the memory and com- 
poses discriminators for assigning the variable length 
register and used areas therein. The first selectors read 
data stored in the used areas, which are assigned in the 



specified variable length register, in accordance with the 
discriminators composed in the decoder, and coordi- 
nates the areas storing the data therein. An arithmetic 
logical unit earned out operations based on the data 
read from the first selectors. The second selector reads 
the data outputted from the arithmetic logical unit, and 
stores them in the variable length register coordinating 
the used areas. 
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Description 

[0001] The invention relates to a register device used 
in a computer as a temporary memory device, and 
especially to a variable length register device, a register s 
length and the number of the registers of which are var- 
iable. 

[0002] An example of conventional variable length 
register devices is disclosed in Japanese patent Kokai 
4-76748. This variable length register device is com- io 
posed of the first selector, which selects lower n bits of 
the first register of N bits (N>n) and outputs them, the 
second selector, which selects upper N-n bits of the first 
register of N bits (N>n) and output them, and an opera- 
tional circuit, which is supplied with the outputs of the is 
first and second selectors and outputs data of N bits by 
carrying out an operation of logical OR. 
[0003] This variable length register device is used in 
case that a memory can be effectively utilized by chang- 
ing a bank address of the memory by a software. 20 
[0004] However, according to the variable length reg- 
ister device disclosed in Japanese patent Kokai 4- 
76748, since an used area in the register cannot be der- 
mined in accordance with the length of the data, the use 
thereof is restricted to assignment of the bank address 25 
of the memory and does not attain to a general register. 
[0005] Moreover, the determination of the register 
length and the number of the registers have important 
meanings in the design of the processor architecture. If 
insufficiency in the registers occurs at the time of a proc- 30 
ess of a application, the throughput deteriorates. If 
redundant registers are provided, the cost of the proc- 
essor increases. In case of application that data of 32 
bits is necessary sometimes, but only lower 16 or 8 bits 
are necessary for the process many times, the number 35 
of utilized bits is far smaller than that of the necessary 
registers, and there arise lots of futility. 
[0006] Accordingly, it is an object of the invention to 
provide a variable length register device, which can be 
utilized not only for assigning addresses in memory but 40 
also as a general register. 

[0007] According to the feature of the invention, an 
variable length register comprises: 

one of more registers, each having a predeter- 4s 
mined number of bits, 

a memory for storing a predetermined program, 
and 

an instruction decoder, which decodes the prede- 
termined program and outputs instructions to so 
assign numbers of bits to be used in the predeter- 
mined number and areas for storing the bits in the 
one or more registers. 

[0008] The invention will be explained in more detail ss 
conjunction with appended drawings, wherein: 

FIG.1 is a block diagram for showing a variable 



length register device according to the preferred 
embodiment of the invention, 
FIQ.2 shows an example of assignment of used 
areas in a variable length register device shown in 
RQ. 1,and 

FIG.3 concretely explains an operation of a variable 
length register device shown in FIG. 1 . 

[0009] Fig.1 is a block diagram for showing a variable 
length register device according to a preferred embodi- 
ment of the invention. 

[001 0] In the variable length register device 1 , a vari- 
able length resister 2, 4-1 selectors 3 and an arithmetic 
logical unit (an ALU, hereinafter) 4 and a 4-1 selector 5 
are successively connected in this order to form a loop, 
and an instruction memory 6, an instruction decoder 7 
and a sequencer 8 are successively connected in this 
order to form another loop. A part of an output of the 
ALU 4 is supplied to the sequencer 8, and an instruction 
decoded by the instruction decoder 7 is supplied to the 
variable length resister 2, the 4-1 selectors 3, the ALU 4 
and the 4-1 selector 5. The variable length resister 
device is connected with an external circuit via an exter- 
nal interface 10 and a control bus 1 1. 
[0011] In the aforementioned structure, an outline of 
the operation will be explained. An instruction to gain 
access to the variable length register 2 is outputted from 
the instruction memory 6, and inputted to the instruction 
decoder 7 to be decoded. As the result, a control signal 
for specifying the variable length register 2 and assign- 
ing an used area therein is generated in the instruction 
decoder 7, transmitted to the variable length decoder 2, 
the 4-1 selectors 3, the ALU 4 and the 4-1 selector 5, 
and inputted to the sequencer 8. 
[001 2] Data in the variable length resister 2 is read on 
the 4-1 selectors 3 and the used areas therein are coor- 
dinated in accordance the instruction supplied from the 
instruction decoder 7. Then, the data are inputted to the 
ALU 4 and operated therein. The operated data is read 
on the 4-1 selector 5 and the used areas therein are 
coordinated. The data in the 4-1 selector 5 is again writ- 
ten into the variable length register 2. At this time, vari- 
ous flags are transmitted to the sequencer 8, and 
following instructions are executed. 
[001 3] F1G.2 shows an example of assignment of the 
used areas. 

[0014] In this example, a register with a length of 32 
bits is assigned as variable length registers of 
8/16/24/32 bits. In this case, it is sometimes necessary 
that every 8 bits is provided with a read/write enable ter- 
minal in accordance with the structure of a hardware of 
the register. 

[001 5] In FIG.2, the used area having the name of B0 
covers 8 bits corresponding to the 0th to 7th bit. the 
same having the name of B1 covers 8 bits correspond- 
ing to the 8th to 15th bit, the same having the name of 
B2 covers 8 bits corresponding to the 16th to the 23rd 
bit, and the same having the name of B3 covers 8 bits 
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corresponding to the 24th to 31st bit. The used area 
having the name of HO covers 16 bits corresponding to 
the Oth to the 1 5th bit and the same having the name of 
H1 covers 16 bits corresponding to the 16th to the 31st 
bit. The used area having the name of 00 covers 24 bits 
corresponding to the Oth to the 23rd bit The used areas 
having the name of WO covers 32 bits corresponding to 
the Oth to the 31st bit. As written additionally in FIG.2, 
the name of the used area is expressed by a binary 
code of 3 bits. 

[001 6] As mentioned in the above, the assignment of 
the used area in the variable length register 2 is speci- 
fied in the instruction to gain access to the variable 
length register 2, and, in such a case, the name of the 
used area (the binary code, in case of a machine word) 
should be combined with a operand. A discriminator for 
specifying a variable length register 2 to be used in the 
several ones is combined with the discriminator for 
assigning the used area. 

[0017] A method for assigning the used area in the 
variable length register 2, the number of the variable 
length resisters and the use of the fixed length register 
jointly with the variable register are suitably selected in 
consideration of a target of application. 
[0018] FIG.3 shows the operation of the variable 
length register device 1 concretely. 
[001 9] An explanation will be given for a case that an 
operational instruction expressed by "Source An (B3) + 
Source Bm (HO) -> Destination (H1)" is outputted from 
the instruction memory 6. This instruction means that 
the data in the n th B3 area in the variable length regis- 
ter 2 of the source A is arithmetically added to the data 
in the m th HO area of the variable length register 2 of 
the source B, and the result obtained is stored in the H1 
area in the destination register. 
[0020] First, the data in the n th B3 area of the variable 
length register 2 of the source A and the data in the m th 
HO area in the variable length register 2 of the source B 
are respectively read on the 4-1 selectors 3 (Step S1), 
and the used areas are coordinated. Since the source A 
assigns the B3 area (8 bits corresponding to the 24th to 
the 31st bit), the data stored therein is closely shifted to 
the B0 area (8 bits corresponding to the Oth to the 7th 
bit) and "0" is stored in the unused area (24 bits corre- 
sponding to the 8th to the 31st bit), before the data is 
inputted to the ALU 4. Moreover, since the source B 
assigns the HO area (1 6 bits corresponding to the Oth to 
the 15th bit), the data stored therein is not shifted to the 
right, but "0" is stored in the unused area (16 bits corre- 
sponding to the 16th to the 31st bit) (Step S2). 
[0021] The data, the used areas of which have been 
coordinated, are inputted to the ALU 4 and arithmeti- 
cally added together, and various flags generated as the 
result of the operation are transmitted to the sequencer 
8. In this example, a carry occurs at the position of the 
16th bit (Step 3). 

[0022] Next, the arithmetically added data is read on 
the 4-1 selector 5, and the used area is coordinated. 



That is to say, since the destination register assigns the 
H1 area (16 bits corresponding to the 16th to the 31st 
bit), the data is shifted to the H1 area (16 bits corre- 
sponding to the 16th to the 31st bit) from the HO area 

s (16 bits corresponding to the Oth to the 15th bit). Finally, 
the data, the used area of which has been coordinated, 
is stored in the destination register. It is enough to 
renew the data stored in the H1 area (Step 4). 
[0023] According to the variable length register device 

10 1 having a structure mentioned in the above, the num- 
bers of the registers in the variable length register 2 can 
be optimized, even in case that the process becomes 
redundant by adopting the fixed length registers in some 
characteristic of application. 

15 [0024] For example, in case that a data bus of 32 its is 
used, several fixed length registers are provided in a 
ordinary processor. However, there arises a circum- 
stance that it is sufficient to process only a part of 32 
bits in some applications. That is to say, in case that 

20 lower 8 bits are truly necessary, upper 24 bits are 
unnecessary and redundant. 
[0025] In order to store four data of 32 bits, in each of 
which only lower 8 bits are truly necessary, H is neces- 
sary to provide four fixed length resisters of 32 bits (32 

25 bits x 4 = 128 bits), and the resister device becomes 
redundant. However, if a variable length register of 32 
bits, which is accessible to the data of 8 bits, is used, the 
four data, each being composed of 8 bits, can be stored 
in a single variable length register, and the number of 

30 the registers can be optimized. 

[0026] As mentioned in the above, since the lengths 
and the number of the registers are variable, a through- 
put can be improved. 

[0027] For example, when the four data, in each of 

35 which only lower 8 bits are truly necessary, are read, the 
data must be read four times in case that the fixed 
length registers of 32 bits are used, and shift/mask is 
necessary in accordance with the structure of a hard- 
ware. On the other hand, in case that the four data, each 

40 being composed of 8 bits, are previously stored in the 
variable length register of 32 bits, read can be com- 
pleted at a time, so that the times of accesses can be 
reduced and the throughput can be improved. 
[0028] For example, in case of the 32 bits fixed length 

45 registers when upper 1 6 bits of 32 hits and lower 1 6 bits 
of 32 bits are separately operated and the results are 
separately stored, it is necessary to carry out excessive 
operations, such as sift, mask, logical operation and 
etc., after the respective operations in order to store the 

so results of the operations. On the other hand, in case of 
the 32 bits variable length registers, since the positions 
of the data to be stored can be directly assigned after 
the respective operations are completed, the excessive 
operations can be reduced and the throughput can be 

55 improved. 

[0029] Moreover, the aforementioned advantage of 
the variable length register can be exhibited in case that 
an external memory is jointly used. 
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[0030] For example, in case that only one or more 32 CI 
bit fixed length registers are built in, when a 32 bit exter- 
nal memory is provided, the data can be transmitted to 1. 
the internal register via a 32 bit bus and the four data, 
each being composed of 8 bits, stored in the 32 bit 5 
external memory are read, it is necessary to adopt a 
method that four data, each being composed of 8 bits, 
are respectively stored in that lower 8 nits of four words 
in the 32 bit external memory, and these data are taken 
into the lower 8 bits of four words of the 32 bit fixed to 
length registers through accesses of four times; or 
another method that the four data, each being com- 
posed of 8 bits, are stored in one word of the 32 bit 
external memory, and the data are taken into one word 
of the 32 bit fixed length register at a time and read four 75 2. 
times, where sift, mask and etc. are necessary in 
accordance with a structure of a hardware. 
[0031 ] However, in case that the 32 bit variable length 
register is built in, the four data, each being composed 
of 8 bits, are stored into one word of the 32 bit external 20 
memory, and the data are taken into the 32 bit variable 
length register at a time, so that excessive operations 
can be reduced and the throughput can be improved. 
[0032] Moreover, according to the variable length reg- 
ister device, since the length of the register and the 25 
number of the registers are variable, consumed electri- 
cal power can be reduced. 

[0033] For example, in case that the 32 bit variable 
length register is used and only lower 8 bits of 32 bits 
are necessary for the process, since it is necessary to 30 
gain access to lower 8 bits and unnecessary to gain 
access to upper 24 bits, the number of accesses and 
excessive operations can be reduced and consumed 
electrical power can be cut down. 
[0034] Other than the method mentioned in the above, 35 
in which a register with a length of 32 bits is assigned as 
a variable length register of 8, 16, 24 or 32 bits, a follow- 
ing method can be adopted. That is to say, fixed length 3. 
registers of 8, 16, 24 and 32 bits are separately pro- 
vided and assigned by means of a compiler at need so 40 
that the group of these fixed length registers apparently 
operate as if a variable length registers. According to 
the later method, although the control of a hardware is 
simplified and an operation speed is improved, since it 
is necessary to limit an application and determine the 45 
optimum combinations of the provided registers in order 
to avoid a failure in the assignment of the registers, 4. 
there arises a disadvantage that it is difficult to keep a 
property of a genera register. 

[0035] As mentioned in the above, according to the so 
invention, since the length of the register and the 
number of the registers are variable, plural information 
can be stored in a single register, the times of accesses 
can be reduced, and, as the result, the throughput is 
improved and consumed electrical power is cut down. ss 



A variable length register device, comprising: 

one of more registers, each having a predeter- 
mined number of bits, 

a memory for storing a predetermined pro- 
gram, and 

an instruction decoder, which decodes said 
predetermined program and outputs instruc- 
tions to assign numbers of bits to be used in 
said predetermined number and areas for stor- 
ing said bits in said one or more registers. 

A variable length register device, comprising: 

a memory for outputting instructions to gain 
access to one or more variable length registers, 
a decoders, which decodes said instructions 
and composes first discriminators for specify- 
ing said one or more variable length registers 
and second discriminators for assigning used 
areas in said specified one or more variable 
length registers, 

first selectors, which read data stored in said 
assigned areas in said specified one or more 
variable length registers in accordance with 
said first and second discriminators and coordi- 
nate areas storing said read data therein, 
an arithmetic logical unit for carrying out a 
operation based on said data supplied from 
said first selectors, and 

a second selector, which reads a result of said 
operation, coordinates an area storing said 
results of said operation and stores them in a 
destination register. 

A variable length register device according to claim 
2, wherein: 

said decoder composes control signals to be 
supplied to said first and second selectors and 
said arithmetic logical unit, and respectively 
transmits them to said first and second selec- 
tors and said arithmetic logical unit. 

A variable length register according to claim 2 or 3, 
wherein: 

said decoder is connected with a sequencer for 
controlling a sequence between said decoder 
and said memory, and 

said arithmetic logical unit composes various 
flags and transmits them to said sequencer. 
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(54) Variable length register device 



(57) It is an object of the invention to provide a var- 
iable length register device which can be used not only 
for assigning an address of a memory but also as a gen- 
eral register A memory outputs an instruction to gain 
access to a variable length register. A decoder decodes 
the instruction supplied from the memory and composes 
discriminators for assigning the variable length register 
and used areas therein. The first selectors read data 



stored in the used areas, which are assigned in the 
specified variable length register, in accordance with the 
discriminators composed in the decoder, and coordi- 
nates the areas storing the data therein. An arithmetic 
logical unit carried out operations based on the data 
read from the first selectors. The second selector reads 
the data outputted from the arithmetic logical unit, and 
stores them in the variable length register coordinating 
the used areas. 
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